// 导出一个axios的实例  而且这个实例要有请求拦截器 响应拦截器
import axios from 'axios'
import store from '@/store'
import router from '@/router'
import { Message } from 'element-ui'

const service = axios.create({
  // baseURL: 'http://ihrm-java.itheima.net', // 设置axios请求的基础的基础地址
  baseURL: process.env.VUE_APP_BASE_API,
  timeout: 5000 // 定义5秒超时
}) // 创建一个axios的实例

// 请求拦截器
service.interceptors.request.use(
  config => {
    const token = store.state.user.token
    // 如果当前存有token,就加在请求头上
    if (token) {
      config.headers['Authorization'] = `Bearer ${token}`
    }
    return config
  }
  , error => {
    return Promise.reject(error)
  })

// 响应拦截器
service.interceptors.response.use(response => {
  if (response.data.success) {
    return response.data
    // 操作成功
  } else {
    // 如果success为false 业务出错,直接触发reject
    // 被catch分支捕获
    return Promise.reject(new Error(response.data.message))
  }
}, async error => {
  console.log('请求错误', error)
  // 处理401报错
  if (error.response.status === 401) {
    // 清空信息 类似用户退出
    await store.dispatch('user/logout')
    router.push('/login')
  }
  Message({
    message: error.response.data.message,
    type: 'error',
    duration: 5 * 1000
  })
  return Promise.reject(error) // 返回执行错误 让当前的执行链跳出成功 直接进入 catch
})
export default service // 导出axios实例
